查看原文
其他

JVM虚拟机图文详解!真香!秒懂!一点都不难!

来自:网络


前言:                                                            

  • 了解Java中的对象、变量等存放的内存区域十分重要

  • 本文将全面讲解Java虚拟机中的内存模型 & 分区,希望你们会喜欢

目录:

1. 内存模型 & 分区

  • Java虚拟机在运行Java程序时,会管理着一块内存区域:
    运行时数据区
  • 在运行时数据区里,会根据用途进行划分:

  1. Java虚拟机栈(栈区)

  2. 本地方法栈

  3. Java堆(堆区)

  4. 方法区

  5. 程序计数器

  • 下面,我将详细介绍每个内存模型分区


2. Java堆:

  • 示意图

  • 简介

3. Java虚拟机栈

  • 示意图

  • 简介

4. 本地方法栈

  • 示意图

  • 简介
    十分类似Java虚拟机栈,与Java虚拟机区别在于:服务对象,即Java虚拟机栈为执行  Java方法服务;本地方法栈为执行  Native方法服务

5. 方法区

  • 示意图

  • 简介

            其内部包含一个运行时常量池,具体介绍如下:

6. 程序计数器

  • 示意图

  • 简介

7. 额外知识:直接内存

  • 定义:NIO类(JDK1.4引入)中基于通道和缓冲区的I/O方式 通过使用Native函数库 直接分配 的堆外内存

  • 特点:不受堆大小限制
  • 应用场景:适用于频繁调用的场景
通过一个 存储在Java堆中的DirectByteBuffer对象 作为这块内存的引用 进行操作,从而避免在Java 堆和 Native堆之间来回复制数据,提高使用性能
  • 抛出的异常:OutOfMemoryError,即与其他内存区域的总和 大于 物理内存限制


  • 本文全面讲解JVM中的内存模型 & 分区,总结如下


-End-


加小编微信:xiaobaito,免费获取一份架构师资料。还可以邀请加入咱们的「菜鸟架构」技术群一起讨论技术,禁止发广告及垃圾信息哦。


热门阅读

免费获取一份架构资料!

只要学会它,再多 Bug 也不怕!

数据库分库分表思路,写得太仔细了吧!

由 HashMap 引发的一个面试10连炮争吵!

Redis 百亿级Key存储方案,太牛逼了!

小白也能看懂的阿里数据中台分析!

公司的API接口被刷了,那是因为你没这样做!

我天!Kafka为什么速度那么快?

更多请关注“菜鸟架构”公众号,将不断呈现更多架构干货!



给个在看,谢谢老板!

    您可能也对以下帖子感兴趣

    文章有问题?点此查看未经处理的缓存